#### IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

In re PATENT APPLICATION of

Yoshihiro SHONA

Serial No.: [NEW]

Mail Stop Patent Application

Filed: September 22, 2003

Attorney Docket No. OKI.573

For: DATA REWRITING METHOD FOR FLASH MEMORY

# **CLAIM OF PRIORITY**

U.S. Patent and Trademark Office 2011 South Clark Place Customer Window, Mail Stop Patent Application Crystal Plaza Two, Lobby, Room 1B03 Arlington, VA 22202

Sir:

Applicant, in the above-identified application, hereby claims the priority date under the International Convention of the following Japanese application:

Appln. No. 2002-364840

filed December 17, 2002

as acknowledged in the Declaration of the subject application.

A certified copy of said application is being submitted herewith.

Respectfully submitted,

**VOLENTINE FRANCOS, PLLC** 

Adam C. Volentine Registration No. 33,289

12200 Sunrise Valley Drive, Suite 150 Reston, Virginia 20191 Tel. (703) 715-0870 Fax. (703) 715-0877

Date: September 22, 2003

# 日本国特許庁 JAPAN PATENT OFFICE

別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office

出願年月日

Date of Application:

2002年12月17日

出 願 番 号

Application Number:

特願2002-364840

[ ST.10/C ]:

[JP2002-364840]

出 願 人
Applicant(s):

沖電気工業株式会社

2003年 4月 8日

特許庁長官 Commissioner, Japan Patent Office



# 特2002-364840

【書類名】

特許願

【整理番号】

MA001418

【提出日】

平成14年12月17日

【あて先】

特許庁長官殿

【国際特許分類】

G11C 16/00

G16F 12/00

【発明者】

【住所又は居所】

東京都港区虎ノ門1丁目7番12号 沖電気工業株式会

社内

【氏名】

正名 芳弘

【特許出願人】

【識別番号】

000000295

【氏名又は名称】 沖電気工業株式会社

【代表者】

篠塚 勝正

【代理人】

【識別番号】

100083840

【弁理士】

【氏名又は名称】

前田 実

【選任した代理人】

【識別番号】

100116964

【弁理士】

【氏名又は名称】 山形 洋一

【手数料の表示】

【予納台帳番号】

007205

【納付金額】

21,000円

【提出物件の目録】

【物件名】

明細書 1

【物件名】

図面 1

【物件名】

要約書 1

# 特2002-364840

【包括委任状番号】 9003703

【包括委任状番号】 0101807

【プルーフの要否】 要

## 【書類名】 明細書

【発明の名称】 データ書き換え装置およびデータ書き換え方法

## 【特許請求の範囲】

【請求項1】 使用するデータ容量よりもN(Nは2以上の整数)個以上多いセクタ数のフラッシュメモリのデータ書き換えをするデータ書き換え装置であって、

セクタを完全に消去するのにかかる時間よりも短い時間で1個のセクタを合計 N回で時分割に消去し、消去中のN個のセクタの書き換えデータを他のセクタに 書き込むことを特徴とするデータ書き換え装置。

【請求項2】 請求項1記載のデータ書き換え装置において、

上記時分割の消去処理は、上記データ書き換えの処理ごとになされることを特徴とするデータ書き換え装置。

【請求項3】 上記データ容量以上のセクタ(以下、データセクタとする)数のフラッシュデータメモリと、2N個以上のセクタ(以下、バッファセクタとする)数のフラッシュバッファとによって構成された上記フラッシュメモリのデータ書き換えをする請求項1記載のデータ書き換え装置であって、

第n(nは1以上の整数)回目のデータ書き換え処理において、第n回目の書き換えデータをバッファセクタに書き込み、

第n回目から第(n+N-1)回目までのデータ書き換え処理において、上記 第n回目の書き換えデータを書き込むべきデータセクタを時分割で消去し、

第(n+N)回目のデータ書き換え処理において、上記バッファセクタに書き込まれている上記第n回目の書き換えデータを、上記時分割で消去したデータセクタに書き込む

ことを特徴とするデータ書き換え装置。

【請求項4】 請求項1記載のデータ書き換え装置において、

第n(nは1以上の整数)回目のデータ書き換え処理において、第n回目の書き換えデータを、被書き換えデータが書き込まれているセクタとは異なる他のセクタに書き込み、

第n回目から第(n+N-1)回目までのデータ書き換え処理において、上記

被書き換えデータが書き込まれていたセクタを時分割で消去する ことを特徴とするデータ書き換え装置。

【請求項5】 使用するデータ容量以上のセクタ(以下、データセクタとする)数のフラッシュデータメモリと、2N(Nは2以上の整数)個以上のセクタ (以下、バッファセクタとする)数のフラッシュバッファとによって構成されたフラッシュメモリのデータをデータ書き換え装置によって書き換えるデータ書き換え方法であって、

データセクタのアドレスがそれぞれ書き込まれる複数のセクタ管理領域を有するセクタ管理手段を、上記フラッシュメモリまたは上記データ書き換え装置に設け、

第n(nは1からNまでのいずれかの整数)のバッファセクタに書き込まれているデータを、第nのセクタ管理領域に書き込まれているアドレスのデータセクタに書き込む第1のステップと、

書き換えデータを第(n+N)のバッファセクタに書き込む第2のステップと

第nのセクタ管理領域に、上記書き換えデータを書き込むべきデータセクタの アドレスを書き込む第3のステップと、

第1から第Nまでのセクタ管理領域に書き込まれているアドレスのN個のデータセクタと、第1から第nまでおよび第(n+1+N)から第2NまでのN個のバッファセクタとを、セクタを完全に消去するのにかかる時間よりも短い時間で同時に消去処理する第4のステップと

#### を有する

ことを特徴とするデータ書き換え方法。

【請求項6】 請求項5記載のデータ書き換え方法において、

上記第1のステップは、書き換えデータのアドレスと重複するアドレスが上記 セクタ管理手段内にあるか否かを判別し、重複するアドレスを無効にし、第nの セクタ管理領域に書き込まれているアドレスが有効であるときにのみ、第nのバ ッファセクタに書き込まれているデータを第nのセクタ管理領域に書き込まれて いるアドレスのデータセクタに書き込むことを特徴とするデータ書き換え方法。 【請求項7】 請求項6記載のデータ書き換え方法において、

上記セクタ管理手段は、

不揮発性メモリで構成された第1のセクタ管理手段と、

フラッシュメモリで構成された第2のセクタ管理手段と を有し、

上記第1のステップにおいては、上記重複するアドレスを上記第1のセクタ管理手段内でのみ無効にし、

上記第2のステップにおいて、書き換えデータを第(n+N)のバッファセクタに書き込んだあとに、上記重複するアドレスを上記第2のセクタ管理手段内で無効にする

ことを特徴とするデータ書き換え方法。

【請求項8】 請求項5記載のデータ書き換え方法において、

読み出しアドレスが上記セクタ管理手段に書き込まれているアドレスであるか否かを判別することによって、読み出しデータがデータセクタに書き込まれているか否かを判別し、データセクタに書き込まれていれば上記フラッシュデータメモリから読み出し、データセクタに書き込まれていなければ上記フラッシュバッファから読み出すことを特徴とするデータ書き換え方法。

【請求項9】 使用するデータ容量よりもN(Nは2以上の整数)個以上多いセクタ数のフラフラッシュメモリのデータをデータ書き換え装置によって書き換えるデータ書き換え方法であって、

データの論理アドレス数と同数のアドレス管理領域を有し、それぞれの論理アドレスのアドレス管理領域にその論理アドレスに割り当てたセクタの物理アドレスが書き込まれたアドレス管理手段と、

セクタの物理アドレスがそれぞれ書き込まれる複数のセクタ管理領域を有する セクタ管理手段と

を上記フラッシュメモリまたは上記データ書き換え装置に設け、

被書き換えデータが書き込まれているセクタとは異なる他のセクタであって第 n (nは1からNまでのいずれかの整数)のセクタ管理領域に書き込まれている物理アドレスのセクタに、書き換えデータとその論理アドレスを書き込む第1の

ステップと、

第nのセクタ管理領域に、上記書き換えデータの論理アドレスのアドレス管理 領域に書き込まれている物理アドレスを書き込む第2のステップと、

上記書き換えデータの論理アドレスのアドレス管理領域を、上記書き換えデータを書き込んだセクタの物理アドレスに書き換える第3のステップと、

第1から第Nまでのセクタ管理領域に書き込まれている物理アドレスのN個のセクタを、セクタを完全に消去するのにかかる時間よりも短い時間で同時に消去処理する第4のステップと

を有する

ことを特徴とするデータ書き換え方法。

【請求項10】 上記データ容量よりも(M+N)(Mは1以上の整数)個以上多いセクタ数のフラッシュメモリのデータをデータ書き換え装置によって書き換える請求項9記載のデータ書き換え方法であって、

上記第1のステップは、

第(m+n)(mは初期値0で最大値Mの整数、nは1からM+Nまでのいずれかの整数)のセクタ管理領域に書き込まれている物理アドレスのセクタに、書き換えデータとその論理アドレスを書き込む第5のステップと、

上記第5のステップで正常に書き込みできたか否かをチェックし、正常の場合には上記第2のステップ進み、異常の場合には、第(m+n)のセクタ管理領域のセクタを不良としたあと、上記mを1つインクリメントして上記第5のステップに戻る第6のステップと

を有し、

上記第4のステップは、 $n \leq N$ のときには第1から第nまでおよび第 (N+M-n+1) から第 (N+M) までのセクタ管理領域に書き込まれている物理アドレスのN個のセクタを、 $n \geq N+1$ のときには第 (n-N+1) から第nまでののN個のセクタを、セクタを完全に消去するのにかかる時間よりも短い時間で同時に消去処理する

ことを特徴とするデータ書き換え方法。

【請求項11】 請求項9記載のデータ書き換え方法において、

読み出し論理アドレスに相当する物理アドレスを、上記アドレス管理手段から 検索し、その物理アドレスのセクタに書き込まれているデータを読み出すことを 特徴とするデータ書き換え方法。

【請求項12】 N(Nは2以上の整数)個のデータセクタよりなるフラッシュデータメモリと、上記データセクタのビット数と同ビット数を有する2N個のバッファセクタよりなるフラッシュバッファとによって構成されたフラッシュメモリのデータをデータ書き換え装置によって書き換えるデータ書き換え方法であって、

上記フラッシュメモリまたは上記データ書き換え装置には、書き換えデータが書き込まれる上記データセクタのアドレスがそれぞれ書き込まれるN個のセクタ管理領域を有するセクタ管理手段が設けられており、

第1のセクタ管理領域にデータ書き換えを行う第1のデータセクタに対応する 第1のアドレスを書き込む第1の工程と、

第1のバッファセクタに、第1の書き換えデータを書き込む第2の工程と、

上記第1のデータセクタにデータが書き込まれている場合、上記第1のデータセクタ、および第2のバッファセクタを含むN個のバッファセクタを1/N時間にて消去し、この消去処理により、上記第2のバッファセクタに書き込まれているデータを完全に消去する第3の工程と、

データ書き換えを行う上記データセクタのアドレスを変更させるごとに、上記第1ないし第3の工程を、異なるセクタ管理領域、および異なるバッファセクタを用いてN回繰り返し、上記第1のデータセクタに書き込まれているデータを完全に消去する第4の工程と、

上記第4の工程のあと、上記第1の書き換えデータを上記第1のデータセクタ に書き込む第5の工程と、

上記第5の工程のあと、上記第1または第4の工程にて上記セクタ管理領域に書き込まれたアドレスに対応する上記データセクタ、および上記第1のバッファセクタと上記第4の工程にて書き換えデータが書き込まれているバッファセクタ以外のN個のバッファセクタを1/N時間にて消去し、この消去処理のあと、少なくとも1つのデータ書き換えを行うデータセクタおよび少なくとも1つのバッ

ファセクタに書き込まれているデータを完全に消去する第6の工程と を備える

ことを特徴とするデータ書き換え方法。

【請求項13】 (N+1) (Nは2以上の整数) 個のデータセクタよりなるフラッシュメモリのデータをデータ書き換え装置によって書き換えるデータ書き換え方法であって、

上記フラッシュメモリまたは上記データ書き換え装置には、上記データセクタのそれぞれに割り当てられる論理アドレス数と同数のアドレス管理領域を有し、それぞれの上記アドレス管理領域に上記論理アドレスが割り当てられた上記データセクタの物理アドレスのそれぞれが書き込まれたアドレス管理手段と、上記データセクタの物理アドレスのそれぞれが書き込まれる(N+1)個のセクタ管理領域を有するセクタ管理領域とが設けられており、

上記セクタ管理手段の第1のセクタ管理領域に書き込まれた物理アドレスに対応する上記データセクタの少なくとも1つは、被書き換えデータが書き込まれているデータセクタとは異なる他のデータセクタであって、かつデータが消去された消去状態となっており、

上記被書き換えデータが書き込まれたデータセクタに割り当てられた物理アド レスを上記アドレス管理手段の第1のアドレス管理領域に書き込む第1の工程と

上記セクタ管理手段の第1のセクタ管理領域に書き込まれた物理アドレスに対応する上記データセクタに第1の書き換えデータを書き込む第2の工程と、

上記第1の工程にて上記アドレス管理手段の第1のアドレス管理領域に書き込まれた物理アドレスを上記セクタ管理手段の第(N+1)のセクタ管理領域に書き込む第3の工程と、

上記第1の書き換えデータが書き込まれた上記データセクタに割り当てられた物理アドレスを上記アドレス管理手段の第1のアドレス管理領域に書き込む第4の工程と、

上記セクタ管理手段の第2から第(N+1)までのセクタ管理領域に書き込まれた物理アドレスに対応するN個の上記データセクタを1/N時間で消去し、上

記セクタ管理手段の第2のセクタ管理領域に書き込まれた物理アドレスに対応するデータセクタのデータを完全に消去する第5の工程と

# を備える

ことを特徴とするデータ書き換え方法。

【請求項14】 使用するデータ容量よりもN(Nは2以上の整数)個以上 多いセクタ数のフラッシュメモリのデータ書き換えをするデータ書き換え装置で あって、

請求項5から13までのいずれかに記載のデータ書き換え方法によって書き換えをすることを特徴とするデータ書き換え装置。

# 【発明の詳細な説明】

[0001]

【発明の属する技術分野】

本発明は、フラッシュEEPROMメモリ(以下、フラッシュメモリとする)のデータを書き換えるデータ書き換え装置およびデータ書き換え方法に関する。

[0002]

# 【従来の技術】

フラッシュメモリは、不揮発性の複数のメモリセルによって構成されている。フラッシュメモリのデータ書き換えは、消去(イレース: Erase)と書き込み(ライト: Write)の2つがセットになっている。消去は1ページ分または複数ページ分あるいは1セクタ分または複数セクタ分のメモリセルを単位としてなされ、書き込みは1バイト分や1ワード分のメモリセルを単位としてなされ、消去単位は、書き込み単位よりも大きい(例えば、特許文献1参照)。また例えば、消去はメモリセルのフローティングゲートから電子を抜き取ることによってなされ、書き込みはメモリセルのフローティングゲートに電子を注入することによってなされる。このようなフラッシュメモリのデータ書き換えでは、まず消去単位のメモリセルを一括して消去し、そのあと消去単位内のそれぞれの書き込み単位にデータを書き込む。

[0003]

従来のデータ書き換えでは、消去は、セクタを完全に消去できるまで(データ

読み出し時にメモリセルが消去状態であることが識別できるように、例えばフローティングゲートから電子を抜き取ることができるまで)、消去単位内のメモリセルのソースおよびドレインならびにコントロールゲートに継続して所定の消去電圧を印加することによってなされる。同様に、書き込みは、セクタを完全に書き込みできるまで(データ読み出し時にメモリセルが書き込み状態であることが識別できるように、例えばフローティングゲートに電子を注入することができるまで)、書き込み単位内のメモリセルのソースおよびドレインならびにコントロールゲートに継続して所定の書き込み電圧を印加することによってなされる。

[0004]

【特許文献1】

特開平11-85629号公報(図1)

[0005]

【発明が解決しようとする課題】

しかしながら上記従来のデータ書き換えでは、書き込み時間が数10 [μs] と短いのに対し、消去時間が数10 [ms] と非常に長いので、例えばコンタクト付きICカードやコンタクトレスICカードに内蔵されたフラッシュメモリのデータ書き換えのように、数 [ms] で高速にデータ書き換えをする必要がある場合には、データ書き換え時間が長くなり過ぎるという課題があった。

[0006]

本発明は、このような従来の課題を解決するためになされたものであり、高速なデータ書き換えができるデータ書き換え装置およびデータ書き換え方法を提供することを目的とするものである。

[0007]

【課題を解決するための手段】

本発明のデータ書き換え装置は、使用するデータ容量よりもN(Nは2以上の整数)個以上多いセクタ数のフラッシュメモリのデータ書き換えをするデータ書き換え装置であって、セクタを完全に消去するのにかかる時間より短い時間で1個のセクタを合計N回で時分割に消去し、消去中のN個のセクタの書き換えデータを他のセクタに書き込むことを特徴とするものである。

[0008]

【発明の実施の形態】

#### 実施の形態1

図1は本発明の実施の形態1のマイクロコンピュータの機能ブロック図である。この実施の形態1のマイクロコンピュータは、RAM2と、コントロールROM(C-ROM)3aおよびアプリケーションROM(AP-ROM)3bからなるROM3と、制御部4と、データバス5と、アドレスバス6とを備え、フラッシュメモリ部1のデータ書き換えをするデータ書き換え装置を構成している。フラッシュメモリ部1は、例えば、コンタクト付きICカードやコンタクトレスICカードに内蔵されているか、あるいはこの実施の形態1のマイクロコンピュータに内蔵されている。

[0009]

フラッシュメモリ部1は、ユーザデータなどが不揮発に書き込まれるフラッシュメモリを有する。RAM2には、ワークデータ(データ書き換え時の変数データなど)が一時書き込みされる。C-ROM3 aには、フラッシュメモリ部1のデータ書き換えやマイクロコンピュータのその他の制御をするためのデータおよびプログラムが記憶されており、AP-ROM3 bには、ユーザのアプリケーションプログラムが記憶されている。制御部4は、C-ROM3 a内のプログラムに従って、データ書き換えなどを制御する。RAM2、ROM3、制御部4、およびフラッシュメモリ部1は、データバス5およびアドレスバス6によって相互に接続されている。

[0010]

フラッシュメモリ部1のデータ書き換えは、AP-ROM3b内のアプリケーションプログラムからC-ROM3a内のデータ書き換え制御プログラムをコールして、その制御プログラムに従ってなされるので、アプリケーションプログラムは、フラッシュメモリ部1のデータ書き換え制御を気にせずに処理できる。

[0011]

図2はフラッシュメモリ部1の機能ブロック図である。図2に示すように、フラッシュメモリ部1は、フラッシュデータメモリ11およびフラッシュバッファ

12によって構成されたフラッシュメモリと、アドレスラッチ13と、アドレスポインタ14と、読み出し用データ差し替え回路15とを備えている。

[0012]

[フラッシュデータメモリ11]

フラッシュデータメモリ11は、フラッシュメモリで構成され、書き換えデータが書き込まれる32 [バイト] 構成のセクタ (データセクタ) を256個 (データセクタ0, 1, …, 255) 備えており、1セクタ単位または複数セクタ単位の消去と1ワード単位 (2バイト単位) の書き込みが可能になっている。

[0013]

[フラッシュバッファ12]

フラッシュバッファ1 2 は、書き換えデータが一時書き込みされる3 2 [バイト] 構成のデータエリアと、2 [バイト] 構成の管理エリア1 2 b からなる3 4 [バイト] 構成のセクタ (バッファセクタ) を3 2 個 (バッファセクタ0, 1, …, 3 1) 備えており、1 セクタ単位または複数セクタ単位の消去と1 ワード単位の書き込みが可能になっている。フラッシュバッファ1 2 のバッファセクタ0~3 1 の管理エリア1 2 b は、データセクタのセクタアドレスが書き込まれるセクタ管理手段を構成している。

[0014]

フラッシュデータメモリ11とフラッシュバッファ12は、消去時に同時に複数のセクタ(データセクタおよびバッファセクタ)を選択できるようになっており、同時に複数のセクタを消去できる構成になっている。

[0015]

図3は管理エリア11aのビット構成図である。図3に示すように、それぞれのバッファセクタに設けられた2 [バイト] の管理エリア12aは、書き換えアドレスが書き込まれるセクタアドレスエリア12b (bit7-bit0の8 [ビット])と、有効フラグが書き込まれる有効フラグエリア12c (bit8の1 [ビット])と、重複フラグが書き込まれる重複フラグエリア12d (bit9の1 [ビット])と、セクタポインタが書き込まれるセクタポインタエリア12e (bit13-bit10の4 [ビット])と、未使用ビットエリア (bi

t 15, bit 14の2 [ビット]) とによって構成されている。

[0016]

上記の書き換えアドレスは、そのバッファセクタのデータエリアに一時書き込みされた書き換えデータを書き込むべきデータセクタのセクタアドレスである。また、有効フラグエリア12cの有効フラグおよび重複フラグエリア12dの重複フラグは、そのバッファセクタのセクタアドレスエリア12bの書き換えアドレスおよびデータエリアのデータが有効であるか無効であるかを示すフラグである。

[0017]

[アドレスラッチ13]

アドレスラッチ13は、管理エリア12aの下位9ビット(有効フラグエリア12cおよびセクタアドレスエリア12b)と同じビット構成の9 [ビット] のラッチエリアを16個(ラッチエリアAdO, Ad1, …, Ad15) 備えている。それぞれのラッチエリアのbit7-bit0には、書き換えアドレスが書き込まれ、bit8には、有効フラグが書き込まれる。このアドレスラッチ13の合計144 [ビット] のラッチ出力は、読み出し用データ差し替え回路15に入力される。このアドレスラッチ13は、バッファセクタの管理エリアと同様に、データセクタのセクタアドレスが書き込まれるセクタ管理手段を構成している。ただし、このアドレスラッチ13では、bit8の有効フラグによって、そのバッファセクタのセクタアドレスエリア12bのセクタアドレスおよびデータエリアのデータが有効であるか無効であるかを示す。

[0018]

[アドレスポインタ14]

アドレスポインタ14は、5 [ビット] のカウンタで構成され、フラッシュバッファ12およびアドレスラッチ13のポインタの役割を果たし、下位4ビット(bit3-bit0)でアドレスラッチ13のラッチエリアの位置を示し、5ビット全体でフラッシュバッファ12のバッファセクタの位置を示す。

[0019]

[読み出し用データ差し替え回路15]

図4は読み出し用データ差し替え回路15の構成例を示す図である。図4において、読み出し用データ差し替え回路15は、144( $9 \times 16$ ) 個のXORゲート15 a と、16 個のNORゲート15 b と、16 個のANDゲート15 c と、16 個のORゲート15 d と、16 個のINVゲート15 e と、32 個のANDゲート15 f とによって構成されている。

[0020]

アドレスバス 6 (図1参照) からの入力アドレスは、13ビット構成であり、その上位8ビット (A12-A5) がセクタアドレスになっている。また、アドレスラッチ13のラッチエリアAdx (xは0,1,…15のいずれか) のラッチ出力では、下位8ビット (bit7-bit0) がセクタアドレス (書き換えアドレス) であり、上位1ビット (bit8) が有効フラグである。

[0021]

それぞれのXORゲート15aは、ラッチエリアAdxのラッチ出力のbit y (yは0, 1, ... 7のいずれか) と、入力アドレスのビットA (y+5) とを 2入力とし、両ビットの同異を比較する。

[0022]

第(x+1)のNORゲート15bは、ラッチエリアAdxのbit7-bit0(データセクタアドレス)についてのXORゲート15aの8出力を入力とする。

[0023]

第(x+1)のANDゲート15cは、ラッチエリアAdxのbit7-bi t0についてのNORゲート15bの出力と、ラッチエリアAdxのbit8(有効フラグ)とを入力とする。

[0024]

ORゲート15dは、16個のANDゲート15cの出力を入力とし、これらの16入力のOR信号を、フラッシュデータメモリ11とフラッシュバッファ12のセレクタ信号BUF/MEMBとしてを出力する。

[0025]

INVゲート15eは、アドレスポインタ14の最上位ビットbit4を入力

とし、その反転信号を出力する。

[0026]

第(2x+1)のANDゲート15fは、第(x+1)のANDゲート15c0の出力と、アドレスポインタ14のbit4とを2入力とし、バッファセクタ(x+16)の選択信号BSEL(x+16)を出力する。また、第(2x+2)のANDゲート15fは、第(x+1)のANDゲート15c0出力と、INVゲート15e0出力とを2入力とし、バッファセクタx0選択信号BSELxを出力する。

[0027]

この実施の形態1では、データセクタは32 [バイト] 構成、バッファセクタは34 (32+2) [バイト] 構成であり、消去単位は1 [セクタ] または複数 [セクタ]、書き込み単位は1 [ワード] (2 [バイト]) である。従って、1 [セクタ] を消去したときには、フラッシュデータメモリ11では16回の書き込みがなされ、フラッシュバッファ12では17回の書き込みがなされる。

[0028]

セクタのデータエリアを32 [バイト] 構成としたフラッシュメモリでは、8 [kバイト] のデータ容量は256 [セクタ] に相当する。フラッシュメモリ部1のフラッシュメモリは、フラッシュデータメモリ11のデータセクタと、フラッシュバッファ12のバッファセクタのデータエリアとを併せて、288 (258+32) [セクタ] で構成されており、8 [kバイト] のデータ容量よりも32 [セクタ] 多い構成になっている。

[0029]

そして、この実施の形態1は、セクタを完全に消去するのにかかる時間よりも短い時間(ただし、セクタを完全に消去するのにかかる時間の1/16の時間以上)でデータ書き換え処理ごとに消去処理をすることによって1個のセクタを合計16回のデータ書き換え処理で時分割に消去し、消去中の16個のデータセクタに書き込むべき書き換えデータをバッファセクタに一時書き込みしておき、このバッファセクタに一時書き込みした書き換えデータを時分割消去が完了したデータセクタに書き込むことを特徴とするものである。

[0030]

# [データ書き換え動作]

このような実施の形態1のデータ書き換え処理は、AP-ROM3b内のアプリケーションプログラムからC-ROM3a内のデータ書き換えサブルーチン(データ書き換え制御プログラム)をコールし、制御部4がそのデータ書き換えサブルーチンに従って制御する。以下に実施の形態1のデータ書き換え動作について説明する。

#### [0031]

図5から図7までは本発明の実施の形態1のデータ書き換え処理を説明する図であって、データ書き換え処理を繰り返したときのフラッシュデータメモリ11、バッファメモリ12、アドレスラッチ13、およびアドレスポインタ14の状態を示す図である。図5から図7までにおいて、(1)は1回目のデータ書き換え処理、(2)は2回目のデータ書き換え処理、(3)は16回目のデータ書き換え処理、(4)は17回目のデータ書き換え処理、(5)は32回目のデータ書き換え処理、(4)は17回目のデータ書き換え処理、(5)は32回目のデータ書き換え処理である。また、図5から図7までおよび以下の説明では、フラッシュデータメモリ11およびフラッシュバッファ12のメモリセルの消去状態を"0"、書き込み状態を"1"としている。

[0032]

#### [1回目のデータ書き換え処理]

図5 (1) の1回目のデータ書き換え処理では、アドレスポインタ14は"0000"であり、アドレスポインタ14が示すバッファセクタ0 (図2参照)のデータエリアには、書き換えデータData1が書き込まれ、上記バッファセクタ0の管理エリア (図2の12aおよび図3参照)には、1回目の書き換えアドレス (書き換えデータData1を書き込むべきデータセクタのアドレス) Add1(bit7-bit0)と、有効フラグ="1"(bit8)と、重複フラグ="0"(bit9)と、セクタポインタ="0001"(bit13-bit10)とが書き込まれる。なお、上記バッファセクタ0は、1回目のデータ書き換え処理の前に消去が完了している。

[0033]

また、1回目のデータ書き換え処理では、アドレスポインタ14の下位4ビット"0000"が示すアドレスラッチ13のラッチエリアAd0(図2参照)には、1回目の書き換えアドレスAdd1(bit7-bit0)と、有効フラグ="1"(bit8)とが書き込まれる。

[0034]

そして、1回目のデータ書き換え処理では、書き換えアドレスAdd1のデータセクタと、バッファセクタ1からバッファセクタ16までの16個のバッファセクタ(アドレスポインタの現データ+1からアドレスポインタの現データ+16までのバッファセクタ)の合計17セクタが同時に消去される。このときの消去時間は、従来の消去時間(セクタを完全に消去できる時間)よりも短く、上記従来の消去時間の1/16以上の時間である。

[0035]

書き換えアドレスAdd1のデータセクタと、バッファセクタ16は、この1回目のデータ書き換え処理での消去が最初の時分割消去となる。消去時間が従来よりも短いので、書き換えアドレスAdd1のデータセクタおよびバッファセクタ16は、中途半端な消去状態で、完全には消去されていない。また、バッファセクタ1は、この1回目のデータ書き換え処理での消去によって完全に消去されたことになる。

[0036]

[2回目のデータ書き換え処理]

図5 (2)の2回目のデータ書き換え処理では、アドレスポインタ14が"00001"にインクリメントされ、アドレスポインタ14が示す第2のバッファセクタのデータエリアには、書き換えデータData2が書き込まれ、上記バッファセクタ1の管理エリア(図2の12aおよび図3参照)には、2回目の書き換えアドレス(書き換えデータData2を書き込むべきデータセクタのアドレス)Add2(bit7-bit0)と、有効フラグ="1"(bit8)と、重複フラグ="0"(bit9)と、セクタポインタ="0001"(bit13-bit10)とが書き込まれる。

[0037]

また、2回目のデータ書き換え処理では、アドレスポインタ14の下位4ビット"0001"が示すアドレスラッチ13のラッチエリアAd1には、2回目の書き換えアドレスAdd2(bit7-bit0)と、有効フラグ="1"(bit8)とが書き込まれる。

[0038]

そして、2回目のデータ書き換え処理では、書き換えアドレスAddl, Add2の2個のデータセクタと、バッファセクタ2からバッファセクタ17までの16個のバッファセクタ(アドレスポインタの現データ+1からアドレスポインタの現データ+16までのバッファセクタ)の合計18セクタが同時に消去される。このときの消去時間も、上記1回目のデータ書き換え処理のときと同じである。

[0039]

書き換えアドレスAdd2のデータセクタおよびバッファセクタ17は、この2回目のデータ書き換え処理での消去が最初の時分割消去となり、書き換えアドレスAdd1のデータセクタおよびバッファセクタ16は、この2回目のデータ書き換え処理での消去が2回目の時分割消去となり、バッファセクタ2は、この2回目のデータ書き換え処理での消去によって完全に消去されたことになる。

[0040]

[3回目から15回目までのデータ書き換え処理]

3回目から15回目までのデータ書き換え処理では、上記1回目および2回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、アドレスポインタ14が"00010", "00011", …, "01110" とインクリメントされ、アドレスポインタ14が示すバッファセクタ2からバッファセクタ14までのデータエリアに、3回目の書き換えデータData3から15回目の書き換えデータData15までが書き込まれ、上記バッファセクタ2からバッファセクタ14までの管理エリアに、3回目の書き換えアドレスAdd3から15回目の書き換えアドレスAdd15までと、有効フラグ="1"と、重複フラグ="0"と、セクタポインタ="0001"とが書き込まれる。

[0041]

また、3回目から15回目までのデータ書き換え処理では、上記1回目および2回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、アドレスポインタ14の下位4ビット"0010","0011",…,"1110"が示すアドレスラッチ13のラッチエリアAd2からラッチエリアAd14までのラッチエリアに、3回目の書き換えアドレスAdd3から15回目の書き換えアドレスAdd15までと、有効フラグ="1"とが書き込まれる。

[004.2]

そして、3回目から15回目までのデータ書き換え処理では、上記1回目および2回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、バッファセクタの管理エリアに書き込まれた書き換えアドレスの複数のデータセクタと、アドレスポインタの現データ+1からアドレスポインタの現データ+16までの16個のバッファセクタとが同時に消去される。

[0043]

# [16回目のデータ書き換え処理]

図 6 (3) の 1 6 回目の書き換え処理では、アドレスポインタ 1 4 が" 0 1 1 1 1" にインクリメントされ、アドレスポインタ 1 4 が示すバッファセクタ 1 5 のデータエリアには、書き換えデータ D a t a 1 6 が書き込まれ、上記バッファセクタ 1 5 の管理エリア(図 2 の 1 2 a および図 3 参照)には、 1 6 回目の書き換えアドレス(書き換えデータ D a t a 1 6 を書き込むべきデータセクタのアドレス)A d d 1 6 (b i t 7 - b i t 0) と、有効フラグ=" 1" (b i t 8) と、重複フラグ=" 0" (b i t 9) と、セクタポインタ=" 0 0 0 1" (b i t 1 3 - b i t 1 0) とが書き込まれる。

[0044]

また、16回目のデータ書き換え処理では、アドレスポインタ14の下位4ビット"1111"が示すアドレスラッチ13のラッチエリアAd15には、16回目の書き換えアドレスAdd16(bit7-bit0)と、有効フラグ="1"(bit8)とが書き込まれる。

[0045]

そして、16回目のデータ書き換え処理では、書き換えアドレスAdd1, A

dd2, …, Add16の16個のデータセクタと、バッファセクタ16からバッファセクタ31までの16個のバッファセクタ(アドレスポインタの現データ+1からアドレスポインタの現データ+16までのバッファセクタ)の合計18セクタが同時に消去される。このときの消去時間も、上記1回目および2回目のデータ書き換え処理のときと同じである。

# [0046]

この16回目のデータ書き換え処理がなされたことによって、アドレスラッチ 13が一杯になり、フラッシュバッファ12が半分埋まる。書き換えアドレス A d d 16のデータセクタおよびバッファセクタ31は、この16回目のデータ書き換え処理での消去が最初の時分割消去となる。また、書き換えアドレス A d d 1のデータセクタおよびバッファセクタ16は、この16回目のデータ書き換え処理での消去が16回目の時分割消去となり、完全に消去されたことになる。

# [0047]

# [17回目のデータ書き換え処理]

図6(4)の17回目のデータ書き換え処理では、アドレスポインタ14が"10000"にインクリメントされ、アドレスポインタ14は、第17のバッファセクタを示し、アドレスポインタ14の下位4ビット"0000"は、上記1回目のデータ書き換え処理と同じアドレスラッチ13のラッチエリアAd0を示す。この17回目のデータ書き換え処理では、上記ラッチエリアAd0の有効フラグ(アドレスポインタの現データー16のバッファセクタであるバッファセクタの管理エリアの有効フラグ)が、データ書き換え処理前にすでに"1"になっているので、上記バッファセクタ0に書き込まれている書き換えデータData1を、上記ラッチエリアAd0(上記バッファセクタ0の管理エリア)に書き込まれている1回目の書き換えアドレスAdd1のデータセクタに書き込み、一時保管のバッファセクタからデータセクタに移す。

# [0048]

なお、上記1回目から16回目までの書き換え処理では、ラッチエリアAd0からラッチエリアAd15までのラッチエリアの有効フラグ (バッファセクタ16からバッファセクタ30までの管理エリアの有効フラグ) はデータ書き換え処

理前には"1"になっていないので、バッファセクタ16からバッファセクタ3 0までのデータエリアのデータをデータセクタに移す処理はされない。

# [0049]

また、17回目のデータ書き換え処理では、アドレスポインタ14が示すバッファセクタ16のデータエリアには、書き換えデータData17が書き込まれ、上記バッファセクタ16の管理エリア(図2の12aおよび図3参照)には、<math>17回目の書き換えアドレス(書き換えデータData17を書き込むべきデータセクタのアドレス)Add17(bit7-bit0)と、有効フラグ="1"(bit8)と、重複フラグ="0"(bit9)と、セクタポインタ="001"(bit13-bit10)とが書き込まれる。

# [0050]

また、17回目のデータ書き換え処理では、1回目の書き換えデータData1をデータセクタに移したあと、アドレスポインタ<math>14の下位4ビットが示すアドレスラッチ13の上記ラッチエリアAdOでは、上記1回目の書き換えアドレスAdd1(bit7-bit0)が17回目の書き換えアドレスAdd<math>17(bit7-bit0)に書き換えられるとともに、有効フラグ="1"(bit8)が書き込まれる。

#### [0051]

そして、17回目のデータ書き換え処理では、書き換えアドレスAdd2, Add3, …, Add17の16個のデータセクタと、バッファセクタ0およびバッファセクタ17からバッファセクタ31までの16個のバッファセクタ(アドレスポインタの現データ+16までのバッファセクタ)の合計32セクタが同時に消去される。このときの消去時間も、上記1回目および2回目のデータ書き換え処理のときと同じである。

#### [0052]

書き換えアドレスAdd17のデータセクタおよびバッファセクタ0は、この17回目のデータ書き換え処理での消去が最初の時分割消去となる。また、書き換えアドレスAdd2のデータセクタおよびバッファセクタ17は、この17回目のデータ書き換え処理での消去が16回目の時分割消去となり、完全に消去さ



れたことになる。

[0053]

# [18回目から31回目までのデータ書き換え処理]

18回目から31回目までのデータ書き換え処理では、上記17回目のデータ 書き換え処理と同様に、データ書き換え処理ごとに、アドレスポインタ14が"  $1\,0\,0\,0\,1$  " , "  $0\,0\,0\,1\,0$  " , … , "  $1\,1\,1\,1\,0$  " とインクリメントされ、ア ドレスポインタ14は、バッファセクタ17からバッファセクタ30までを順次 示し、アドレスポインタ14の下位4ビット"0001", "0010", …, "1110"は、上記2回目から15回目までのデータ書き換え処理と同じアド レスラッチ13のラッチエリアAdlからラッチエリアAdl4までを順次示す 。これら18回目から31回目までのデータ書き換え処理では、上記ラッチエリ アAd1からラッチエリアAd14の有効フラグ(バッファセクタ1からバッフ ァセクタ14までの管理エリアの有効フラグ)がいずれも"1"なので、上記バ ッファセクタ1からバッファセクタ14までに一時書き込みされていた書き換え データData2, Data3, …, Data15を、上記ラッチエリアAd1 からラッチエリアAd14(上記バッファセクタ1からからバッファセクタ14 までの管理エリア)に書き込まれている2回目から15回目までの書き換えアド レスAdd2, Add3, …, Add15のデータセクタに書き込んで移す処理 をする。

[0054]

また、18回目から31回目までのデータ書き換え処理では、上記17回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、アドレスポインタ14が示すバッファセクタ17からバッファセクタ30までのデータエリアに、18回目の書き換えデータData31までが書き込まれ、上記バッファセクタ17からバッファセクタ30までの管理エリアに、18回目の書き換えアドレスAdd18から31回目の書き換えアドレスAdd31までと、有効フラグ="1"と、重複フラグ="0"と、セクタポインタ="0001"とが書き込まれる。

[0055]



また、18回目から31回目までのデータ書き換え処理では、上記17回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、2回目の書き換えデータData15までをデータセクタに移したあと、アドレスポインタ14の下位4ビットが示すアドレスラッチ13の上記ラッチエリアAd1からラッチエリアAd14では、上記2回目の書き換えアドレスAdd15までが、それぞれ18回目の書き換えアドレスAdd15までが、それぞれ18回目の書き換えアドレスAdd18から31回目の書き換えアドレスAdd31までに書き換えられるとともに、有効フラグ="1"が書き込まれる

## [0056]

そして、18回目から31回目までのデータ書き換え処理では、上記17回目のデータ書き換え処理と同様に、データ書き換え処理ごとに、バッファセクタの管理エリアに書き込まれた書き換えアドレスの16個のデータセクタと、アドレスポインタの現データ+1からアドレスポインタの現データ+16までの16個のバッファセクタとが同時に消去される。

#### [0057]

# [32回目の書き換え処理]

図7 (5) の32回目の書き換え処理では、アドレスポインタ14が"1111"にインクリメントされ、アドレスポインタ14は、バッファセクタ31を示し、アドレスポインタ14の下位4ビット"1111"は、上記16回目のデータ書き換え処理と同じアドレスラッチ13のラッチエリアAd15を示す。この32回目のデータ書き換え処理では、上記ラッチエリアAd15の有効フラグ(アドレスポインタの現データー16のバッファセクタであるバッファセクタ15の管理エリアの有効フラグ)が、データ書き換え処理前にすでに"1"になっているので、上記バッファセクタ15に書き込まれている書き換えデータData16を、上記ラッチエリアAd15(上記バッファセクタ15の管理エリア)に書き込まれている16回目の書き換えアドレスAdd16のデータセクタに書き込み、一時保管のバッファセクタからデータセクタに移す。

[0058]

また、32回目のデータ書き換え処理では、アドレスポインタ14が示すバッファセクタ31のデータエリアには、書き換えデータData32が書き込まれ、上記バッファセクタ31の管理エリア(図2の12aおよび図3参照)には、<math>32回目の書き換えアドレス(書き換えデータData32を書き込むべきデータセクタのアドレス)Add32(bit7-bit0)と、有効フラグ="1"(bit8)と、重複フラグ="0"(bit9)と、セクタポインタ="001"(bit13-bit10)とが書き込まれる。

#### [0059]

また、32回目のデータ書き換え処理では、<math>16回目の書き換えデータData16をデータセクタに移したあと、アドレスポインタ14の下位4ビットが示すアドレスラッチ13の上記ラッチエリアAd15では、上記16回目の書き換えアドレスAdd16(bit7-bit0)が32回目の書き換えアドレスAdd32(bit7-bit0)に書き換えられるとともに、有効フラグ="1"(bit8)が書き込まれる。

## [.0060]

そして、32回目のデータ書き換え処理では、書き換えアドレスAdd17, Add18, …, Add32の16個のデータセクタと、バッファセクタ0からバッファセクタ15までの16個のバッファセクタ(アドレスポインタの現データ+1からアドレスポインタの現データ+16までのバッファセクタ)の合計32セクタが同時に消去される。このときの消去時間も、上記1回目および2回目のデータ書き換え処理のときと同じである。

#### [0061]

この32回目のデータ書き換え処理がなされたことによって、アドレスラッチ 13が再び一杯になり、フラッシュバッファ12が全て埋まる。書き換えアドレスAdd32のデータセクタは、この32回目のデータ書き換え処理での消去が 最初の時分割消去となる。バッファセクタ15も、この32回目のデータ書き換え処理での消去が、2度目の消去においての最初の時分割消去となる。また、書き換えアドレスAdd17のデータセクタおよびバッファセクタ0は、この32回目のデータ書き換え処理での消去が16回目の時分割消去となり、完全に消去

されたことになる。

[0062]

33回目のデータ書き換え処理は、上記1回目のデータ書き換え処理に、一時保管の書き換えデータをバッファセクタからデータセクタに移す処理を追加したものと同様である。つまり、33回目以降のデータ書き換え処理では、図5(1)から図7(5)までと同様の処理が繰り返される。このようなデータ書き換え処理の繰り返しによって、データセクタおよびバッファセクタは、時分割で順次消去され、書き換えデータは、消去が完了したバッファセクタに順次一時書き込みされ、消去が完了したデータセクタに順次移される。

[0063]

ただし、33回目以降のデータ書き換え処理では、バッファセクタの管理エリアには、セクタポインタ="0010"(bit13-bit10、図3の12 e参照)が書き込まれる。さらに、その次の32回のデータ書き換え処理である65回目以降のデータ書き換え処理では、セクタポインタ="0100"が書き込まれる。このようにセクタポインタは、32回のデータ書き換え処理ごとに、"1"となるビットをシフトして書き込まれる。これは電源投入時のバッファセクタの最初の書き込み位置(電源投入前のバッファセクタの最後の書き込み位置)を識別するための手法である。なお、電源投入時の初期化処理については、あとで説明する。

[0064]

図8は本発明の実施の形態1のデータ書き換え処理を示すフローチャートである。図8および以下の説明では、フラッシュデータメモリ11およびフラッシュバッファ12のメモリセルの消去状態を"0"、書き込み状態を"1"としている。

[0065]

図8および以下の説明において、Pはアドレスポインタ14にセットされたデータ(ポインタデータ)である。また、LAT [P] は、アドレスラッチ13のラッチエリアであって、ポインタデータPの下位4 [ビット] が示す位置のラッチエリアである。

[0066]

また、BUF [P], BUF [P-16], BUF [P+1], BUF [P+16] は、それぞれバッファセクタであって、BUF [P] は、ポインタデータ Pの位置のバッファセクタであり、BUF [P-16], BUF [P+1], BUF [P+16] は、それぞれデータP-16, P+1, P+16をポインタデータとしたときの位置のバッファセクタである。ただし、ここでは32個のバッファセクタをサイクリックに使用するため、P-16およびP+16は、いずれもポインタデータPに16を加算し、その値を32で除算した剰余である。つまり、P-16およびP+16は、

 $(P+16) \mod 32$ 

なる演算で求めた値である。また、P+1は、ポインタデータPに1を加算し、その値を32で除算した剰余である。つまり、P+1は、

(P+1) mod 3 2

なる演算で求めた値である。

[0067]

また、MEM [LAT [P]] は、データセクタであって、ラッチエリアLAT [P] に書き込まれた書き換えアドレスのデータセクタである。同時に、MEM [LAT [P]] は、バッファセクタBUF [P] またはBUF [P-16]の管理エリア(図2の12aおよび図3参照)に書き込まれた書き換えアドレスのデータセクタでもある。

[0068]

[ステップS1]

まず図8のステップS1で、ポインタデータPに1を加算して更新する。ただし、ここでは32個のバッファセクタをサイクリックに使用するため、実際には、ポインタデータPに1を加算し、その値を32で除算して、その剰余でポインタデータPを更新する。つまり、

(P+1) mod 3 2

なる演算で求めた値でポインタデータPを更新する。

[0069]

## [XFyJS2, S3]

次にステップS2で、今回の書き換えアドレスが、すでにアドレスラッチ13に書き込まれている書き換えアドレスと重複しているか否かを判別し、重複している書き換えアドレスが動れば、ステップS3で、書き換えアドレスが重複しているバッファセクタの管理エリア(図2の12aおよび図3参照)の重複フラグ(bit9、図3の12d参照)に"1"を書き込み、さらにステップS4で、書き換えアドレスが重複しているアドレスラッチ13のラッチエリア内の有効フラグ(bit8)に"0"を書き込み、ステップS5に進む。また、上記ステップS2で重複している書き換えアドレスがなければ、ステップS5に進む。

#### [0070]

なお、上記ステップS3,S4で、書き換えアドレスの重複を識別するために、アドレスラッチ13のラッチエリアでは、有効フラグに" 0 "を書き込んで、そのラッチエリアに書き込まれた書き換えアドレスを無効にしているが、バッファセクタの管理エリアでは、重複フラグに" 1 "を書き込んで、その管理エリアに書き込まれた書き換えアドレスを無効にしている。これは、管理エリアの有効フラグを" 0 "に消去するには、そのバッファセクタを消去しなけでばならず、時間がかかるからである。また、上記図5から図7まででは、書き換えアドレスの重複はないものとして説明した。

#### [007.1]

#### [ステップS5]

ステップS5では、ラッチエリアLAT [P] に書き込まれた有効フラグ(bit8)が"1"か否かを判別することによって、そのラッチエリアLAT [P] に書き込まれている書き換えアドレスが有効であるか否かを判別し、上記の有効フラグが"1"であればステップS6に進み、"0"であればステップS7に進む。

#### [0072]

このステップS5では、ラッチエリアLAT[P]はまだ更新前なので、ラッチエリアLAT[P]には、バッファセクタBUF[P-16]の管理エリアに書き込まれているものに相当する書き換えアドレスおよび有効フラグが書き込ま

れている。この更新前のラッチエリアLAT [P] の有効フラグ (bit 8) は、バッファセクタBUF [P-16] に、データセクタMEM [LAT [P]] に書き込む有効な書き換えデータがあるか否かを示すフラグであって、有効な書き換えデータがある場合には"1"となり、今回の書き換え処理およびその15回前までの書き換え処理において書き換えアドレスが重複して無効になった場合や、バッファセクタBUF [P-16] がまだ未使用の場合には、無効であることを示す"0"となる。

[0073]

[ステップS6]

ステップS6では、バッファセクタBUF[P-16]に一時書き込みされている有効な書き換えデータを、データセクタMEM[LAT[P]]に書き込む

[0074]

上記ステップS6では、ワード単位の書き込みになるので、16回の書き込み処理をすることになる。ここで、1[ワード]の書き込み時間を $20[\mu s]$ とすると、この書き込み処理に $320[\mu s]$ かかることになる。

[0075]

また、上記ステップS6で、データセクタに書き込まれる書き換えデータは、16回前のデータ書き換え処理においてバッファセクタBUF [P-16] に一時書き込みされた書き換えデータである。従って、上記ステップS6は、本来書き込まれるべきデータセクタMEM [LAT [P]] に、上記バッファセクタBUF [P-16] に一時書き込みされた書き換えデータを移す処理となる。

[0076]

[ステップS7]

次にステップS7で、バッファセクタBUF [P] のデータエリアに、今回の書き換えデータを書き込むとともに、バッファセクタBUF [P] の管理エリアに、今回の書き換えアドレス(bit7-bit0)および有効フラグ="1"(bit8)を書き込む。

[0077]

上記ステップ S 7 においても、ワード単位の書き込みで 1 7 回書き込むことになるので、この書き込み処理に 3 4 0 [  $\mu$  s ] かかることになる。

[0078]

[ステップS8]

次にステップS8で、ラッチエリアLAT[P]に、今回の書き換えアドレス (bit7-bit0) および有効フラグ="1"(bit8) を書き込んで、ラッチエリアLAT[P] を更新する。

[0079]

[ステップS9]

最後にステップS9で、16個のデータセクタMEM[LAT[P-15]] ~MEM[LAT[P]] の内で、書き換えアドレスが有効な(ラッチエリアに書き込まれた有効フラグが"1"である)全てのデータセクタと、16個のバッファセクタBUF[P+1] ~BUF[P+16] とを同時に消去する。

[0080]

なお、この実施の形態1では、フラッシュデータメモリ11およびフラッシュ バッファ12のデコーダは複数のセクタを同時に選択できるようになっているの で、同時に複数のデータセクタおよび複数のバッファセクタを消去することがで きる。

[0081]

また、この実施の形態 1 では、データ書き換え処理ごとの 1 6 回の時分割消去によってそれぞれのセクタを完全に消去するので、上記ステップ S 9 での消去時間は、従来の消去時間の 1/1 6 の時間とすることができる。例えば、セクタの完全な消去に 2 0 [ms] 必要な場合は、1 2 5 [ms] の消去時間となる。

[0082]

以上で1回のデータ書き換え処理が完了したことになり、ソフト処理を除いた1回のデータ書き換え処理時間は、アドレス重複がない場合で0.32+0.34+1.25=1.91 [ms] となり、アドレス重複があった場合でも管理エリアの書き込みが1回増えるだけなので、2 [ms] 以内で完了できる計算になる。

[0083]

#### [初期設定処理]

上記電源投入時の初期設定処理について以下に説明する。アドレスラッチ13 およびアドレスポインタ14は、揮発性記憶手段(レジスタやカウンタ)で構成されており、電源が切れるとデータが消えてしまうので、電源投入時には、アドレスラッチ13およびアドレスポインタ14を初期設定できるようにする必要がある。そのためには、電源投入時のバッファセクタの最初の書き込み位置(電源投入前のバッファセクタの最後の書き込み位置)を識別できるようにする必要がある。

#### [0084]

そこで、この実施の形態1では、揮発性記憶手段で構成された第1のセクタ管理手段であるアドレスラッチ13の他に、フラッシュメモリで構成された第2のセクタ管理手段であるフラッシュバッファ12の管理エリア12aとによって、セクタ管理手段を構成し、電源が切れてもデータを保持できるフラッシュバッファ12の管理エリア12a内に設けたセクタポインタを参照することによって、電源投入時の最初の書き込み位置(電源投入前の最後の書き込み位置)を識別でき、アドレスラッチ13およびアドレスポインタ14を初期設定できるようにしている。

#### [0085]

セクタポインタは、上記図5から図7までにおいて説明したように、"000 1","0010","0100"というように、32回のデータ書き換え処理 ごとに"1"となるビットをシフトして書き込まれる。

#### [0086]

電源投入時に、管理エリア12aのセクタポインタを、バッファセクタ0から バッファセクタ31の順で参照していき、まずセクタポインタが"0000"で ないバッファセクタを探し、そこからさらにセクタポインタが"0000"であ るバッファセクタを探す。

#### [0087]

バッファセクタ〇からバッファセクタ31の順で参照したとき、セクタポイン

タが"0000"でないデータから"0000"になった最初のバッファセクタが、電源投入時の最初の書き込み位置となり、そのバッファセクタの1個前のバッファセクタ(セクタポインタが"0000"でない最後のバッファセクタ)が電源投入前の最後の書き込み位置となるので、アドレスポインタ14には、この電源投入前の最後の書き込み位置を示すデータを初期設定する。

## [0088]

次に、上記初期設定したアドレスポインタ14が示す位置のバッファセクタの管理エリアの下位9ビット(bit7-bit0の書き換えアドレスおよびbit8の有効フラグ、図3の12bおよび12c参照)をアドレスポインタ14の下位4ビットが示す位置のアドレスラッチ13のラッチエリアに書き込む。

## [0089]

さらに、現アドレスポインタデーター1の位置から現アドレスポインタデーター16の位置までの管理エリア12aの下位9ビットを、それぞれ現アドレスポインタデーター1の下位4ビットの位置から現アドレスポインタデーター16の下位4ビットの位置までのアドレスラッチ13のラッチエリアにそれぞれ書き込む。以上で、アドレスラッチ13およびアドレスポインタ14の初期設定が完了する。

#### [0090]

ここで、セクタポインタ(図3の12e参照)に、"1"にするビットの位置を変えたポインタを使用しているのは、バッファセクタの消去が16回のデータ書き換え処理での時分割消去によってなされるため、管理エリア12aによっては中途半端な消去状態(消去途中の状態)のものが存在するが、このような消去途中の管理エリア12aを含んでいても、電源投入時の最初の書き込み位置(電源投入前の最後の書き込み位置)を確実に識別することができるようにするためである。

#### [0091]

以上の初期設定処理によって電源投入時にアドレスラッチ13およびアドレスポインタ14を確実に初期設定することができる。

#### [0092]

このような初期設定処理は、C-ROM3a内にサブルーチンとして用意しておけば、AP-ROM3b内のアプリケーションプログラムからC-ROM3a内の初期設定サブルーチン(初期設定制御プログラム)をコールし、制御部4がその初期設定サブルーチンに従って制御する。

[0093]

## 「データ読み出し動作]

実施の形態1のデータ読み出し動作について以下に説明する。アドレスラッチ13に書き込まれているセクタアドレスのデータセクタは消去中であるため、このデータを読み出す場合には、バッファセクタに一時書き込みされているデータに差し替えて読み出す必要がある。このため、読み出しセクタアドレスがアドレスラッチ13に書き込まれているものか否かを判別することによって、読み出しデータが、データセクタに移される前のバッファセクタに一時書き込みされているデータであるか、すでにデータセクタに書き込まれたデータであるかを判別し、データセクタに書き込まれる前のバッファセクタに一時書き込みされているデータであればそのバッファセクタから読み出し、すでにデータセクタに書き込まれているデータであればそのデータセクタから読み出す処理が必要である。

#### [0094]

このようなデータ読み出し処理は、読み出し用データ差し替え回路15(図1 および図4参照)によってなされる。図4の読み出し用データ差し替え回路15において、アドレスラッチ13のラッチエリアAdxから出力されたセクタアドレス(bit7-bit0)は、8個のXORゲート15aによって、読み出しセクタアドレス(読み出しアドレスの上位8ビット)A12-A5と比較され、全てのビットが一致した場合にのみ、第(x+1)のNORゲート15bの出力が"H"(High)になる。

#### [0095]

また、ラッチエリアAdxから出力された有効フラグ(bit8)は、重複した書き換えアドレスの書き換えデータが一時書き込みされたバッファセクタや未使用のバッファセクタではそのバッファセクタの管理エリアのアドレスおよびデータエリアのデータが無効であることを示す"0"("L"(Low))であり

、重複していない書き換えアドレスの書き換えデータが一時書き込みされている バッファセクタではそのバッファセクタの管理エリアに書き込まれている書き換 えアドレスおよびデータエリアに書き込まれている書き換えデータが有効である ことを示す"1"("H")である。

#### [0096]

このため、読み出しセクタアドレスがラッチエリアAdxに書き込まれているセクタアドレス(書き換えアドレス)と一致し、かつその書き換えアドレスおよび書き換えデータが有効である場合にのみ、第(x+1)のANDゲート15cの出力は"H"になる。

#### [0097]

第1から第16までのANDゲート15cの出力はORゲート15dに入力され、ORゲート15dの出力であるセレクタ信号BUF/MEMBは、いずれかのANDゲート15cの出力が"H"であれば、バッファセクタからの読み出しを示す"H"となり、全てのANDゲート15cの出力が"L"であれば、データセクタからの読み出しを示す"L"となる。

## [0098]

また、アドレスポインタ14の最上位ビット(bit4)の出力と第(x+1)のANDゲート15cの出力とを第(2x+1)のANDゲート15fに入力して、バッファセクタ(x+16)の選択信号BSEL(x+16)を生成し、アドレスポインタ14の最上位ビット(bit4)の反転出力(INVゲート15eの出力)と第(x+1)のANDゲート15cの出力とを第(2x+2)のANDゲート15fに入力して、バッファセクタxの選択信号BSELxを生成する。

#### [0099]

このように、読み出しセクタアドレスがアドレスラッチ 13016個のラッチエリアAd0~Ad15に書き込まれたセクタアドレス(書き換えアドレス)のいずれかと一致し、かつそのラッチエリアに書き込まれた有効フラグが"1"の場合には、セレクタ信号BUF/MEMBがフラッシュバッファ12からの読み出しを示す"H"になるとともに、バッファセクタの選択信号BSEL0~BS

EL31のいずれかが"H"になり、そのフラッシュバッファセクタに一時書き込みされているデータが読み出されることになる。選択信号BSELxが"H"であれば、バッファセクタx(第(x+1)のバッファセクタ)のデータエリアに一時書き込みされいる書き換えデータが読み出される。

# [0100]

また、読み出しセクタアドレスがアドレスラッチ13の16個のラッチエリア A d O ~ A d 1 5 に書き込まれたセクタアドレス(書き換えアドレス)のいずれ とも一致しなければ、セレクタ信号BUF/MEMBがフラッシュデータメモリ 1 1 からの読み出しを示す"L"になり、読み出しセクタアドレスのデータバッファに書き込まれているデータが読み出される。

#### [0101]

以上のように実施の形態1によれば、書き換えデータおよび書き換えアドレスをバッファセクタに一時書き込みし、上記書き換えアドレスのデータセクタを、完全な消去にかかる時間の1/16の時間ずつの消去処理によって、16回のデータ書き換え処理で時分割で消去し、消去が完了した上記データセクタに、上記バッファセクタに一時書き込みした書き換えデータを書き込んで移すことにより、1回のデータ書き換え処理にかかる時間を短くできる。

#### [0102]

また、読み出し用データ差し替え回路15によってデータセクタおよびバッファセクタからのデータ読み出しを制御することにより、データセクタに書き込まれていないデータの読み出しをアプリケーションプログラムで意識する必要がなく、データ読み出し処理時間を短くできる。

#### [0103]

また、目標の書き換え処理時間になるように時分割して消去するので、長時間 の消去処理のためのバックアップ電源が必要ない。

#### [0104]

また、16回のデータ書き換え処理中にアドレスが重複した場合、最新の書き換えデータのみがデータセクタに書き込まれるので、フラッシュデータメモリ1 1の書き換え回数を少なくできる。 [0105]

### 実施の形態2

本発明の実施の形態2のマイクロコンピュータは、上記実施の形態1のマイクロコンピュータ(図1参照)において、データ書き換え処理の手順の一部を変更したものである。

### [0106]

上記実施の形態1では、図1のステップS2でアドレスの重複を検出すると同時に、ステップS3でバッファセクタの管理エリアに重複フラグ="1"を書き込んで、そのバッファセクタに書き込まれている書き換えアドレスおよび書き換えデータを無効にしている。

### [0107]

しかしながら、このような手順では、新しい書き換えデータおよびその書き換えアドレスをバッファセクタに書き込む処理が完了する前に、アドレスが重複した古いデータを無効にしてしまうため、図1のステップS5からS7までの間に事故などで電源が切れた場合に、有効な書き換えデータが判らなくなってしまう可能性がある。

#### [0108]

そこで、実施の形態2では、新しい書き換えデータをバッファセクタに書き込み完了してから、アドレスが重複した古いデータが書き込まれているバッファセクタの管理エリアに重複フラグ="1"を書き込んで無効にすることによって、フラッシュバッファ12では新旧データの少なくともいずれかが必ず有効になっているので、新しい書き換えデータの一時書き込みの途中で電源が切れても、電源の再投入時の初期設定処理において有効な書き換えデータを識別できる。なお、実施の形態2のマイクロコンピュータの構成は、上記実施の形態1のマイクロコンピュータ(図1および図2参照)と全く同じなので、その説明を省略する。

#### [0109]

図9は本発明の実施の形態2のデータ書き換え処理を示すフローチャートである。なお、図9において、図8に記載のものに相当するものには同じ符号を付してある。また、図9および以下の説明において、DUPFは重複検出フラグ、P

2は書き換えアドレスが重複しているバッファセクタの位置を示すデータ(重複位置データ)が書き込まれる変数であり、これらの重複検出フラグDUPFおよび変数P2はRAM2(図1参照)内に設けられている。また、BUF [P2]は、変数P2に書き込まれた重複位置データが示す位置のバッファセクタである

# [0110]

この図9の実施の形態2のデータ書き換え処理は、上記実施の形態1のデータ書き換え処理(図8参照)において、ステップS1をステップS1、ステップS3をS3、にそれぞれ変更し、ステップS7とS8の間に、ステップS10およびS11を設けたものである。実施の形態2のデータ書き換え処理について、上記実施の形態1のデータ書き換え処理との違いを中心にして以下に説明する。

### [0111]

この実施の形態2のデータ書き換え処理では、RAM2(図1参照)内に重複 検出フラグDUPFを設けてあり、まず図9のステップS1'で、ポインタデー タPをインクリメントして更新するとともに、重複検出フラグDUPFを"0" にする。

### [0112]

上記の重複検出フラグDUPFは、そのデータ書き換え処理において、アドレスの重複が検出されたか否かを示すフラグであり、DUPF="0"はアドレスの重複が検出されなかったことを示し、DUPF="1"はアドレス重複が検出されたことを示す。

#### [0113]

また、この実施の形態2のデータ書き換え処理では、RAM2(図1参照)内に変数P2を設けてあり、ステップS2でアドレスの重複が検出されたら、ステップS3'で、重複検出フラグDUPFを"1"にするとともに、変数P2に、書き換えアドレスが重複しているバッファセクタの位置を示すデータ(重複位置データ)を書き込む。

#### [0114]

ステップ4からステップS7まででは、上記実施の形態1と同様に、バッファ

セクタBUF [P-16] に有効な書き換えデータが一時書き込みされていれば、その書き換えデータをデータセクタMEM [LAT [P]] に書き込み、バッファセクタBUF [P] に、今回の書き換えデータおよび書き換えアドレスを書き込む。なお、アドレスラッチ13のラッチエリアについては、この実施の形態2においても上記実施の形態1と同様に、ステップS2でアドレスの重複を検出すると同時に、ステップS4でラッチエリアの有効フラグを"1"から"0"に書き換えて、そのラッチエリアに書き込まれた書き換えアドレスを無効にしている。

### [0115]

そしてステップS10で、重複検出フラグDUPFが"1"か否かを判別することによって、上記ステップS2でアドレスの重複を検出したか否かを判別し、DUPF="1"ならばステップS11に進み、DUPF="0"ならばステップS8に進む。

# [0116]

ステップ11では、バッファセクタBUF [P2] の管理エリア (図2の12 a および図3参照) の重複フラグ (bit9、図3の12d参照) に"1"を書き込む。なお、ステップS8以降は上記実施の形態1と同様である。

### [0117]

以上のように実施の形態2によれば、書き換えアドレスが重複した場合に、新しい書き換えデータをバッファセクタに書き込み完了してから、アドレスが重複した古いデータが書き込まれているバッファセクタの管理エリアに重複フラグ= "1"を書き込んで無効にすることにより、上記実施の形態1と同様の効果が得られる上に、データ書き換え処理の途中で電源が切れても、有効な書き換えデータを失うことなく完全に復旧できる。

### [0118]

#### 実施の形態3

本発明の実施の形態3のマイクロコンピュータは、上記実施の形態1のマイクロコンピュータ(図1参照)において、主にフラッシュメモリ部1の構成および機能を変更したものである。

### [0119]

図10は本発明の実施の形態3のマイクロコンピュータにおいてのフラッシュメモリ部1の機能ブロック図である。なお、図10において、図2に記載のものに相当するものには同じ符号を付してある。

### [0120]

図10に示すように、実施の形態3のフラッシュメモリ部1は、フラッシュデータメモリ11およびイレースバッファ16によって構成されたフラッシュメモリと、アドレスラッチ13と、アドレスポインタ14と、アドレスRAM17とを備えている。

### [0121]

この実施の形態3のフラッシュメモリ部1は、上記実施の形態1のフラッシュメモリ部1(図2参照)において、フラッシュバッファ12および読み出し用データ差し替え回路15を削除して、イレースバッファ16およびアドレスRAM17を設け、フラッシュデータメモリ11、アドレスラッチ13、およびアドレスポインタ14の構成や機能をそれぞれ変更したものである。

#### [0122]

### [フラッシュデータメモリ11]

実施の形態3のフラッシュデータメモリ11は、フラッシュメモリで構成され、書き換えデータが書き込まれる32 [バイト] 構成のデータエリアと、主に書き換え論理アドレスが書き込まれる2 [バイト] 構成のメモリ管理エリア11aからなる34 [バイト] 構成のセクタ (データセクタ) を288個備えており、1セクタ単位または複数セクタ単位の消去と1ワード単位の書き込みが可能になっている。

# [0123]

図11はメモリ管理エリア11aのビット構成図である。図11に示すように、それぞれのデータセクタに設けられた2 [バイト] のメモリ管理エリア11a は、書き換えデータの論理セクタアドレス(書き換え論理アドレス) が書き込まれる論理セクタアドレスエリア11b(bit7-bit0の8 [ビット]) と、有効セクタフラグが書き込まれる有効セクタフラグエリア11c(bit8の

1 [ビット]) と、不良セクタフラグが書き込まれる不良セクタフラグエリア1 1 d (bit 9の1 [ビット]) と、ダミーデータ"00000"のダミービットエリア(bit 15-bit 10の6 [ビット]) とによって構成されている。

# [0124]

有効セクタフラグエリア11cの有効セクタフラグおよび不良セクタフラグエリア11dの不良セクタフラグは、そのデータセクタが有効であるか無効であるかを示すフラグである。また、上記の不良フラグは、そのデータセクタが不良セクタであるか否かを示すフラグである。

### [0125]

# [イレースバッファ16]

イレースバッファ16は、それぞれ2[バイト]構成の16個のバッファデータエリア16aと、2[バイト]構成のバッファ管理エリア16dからなる34[バイト]構成のセクタ(バッファセクタ)を4個備えており、1セクタ単位または複数セクタ単位の消去と1ワード単位の書き込みが可能になっている。このイレースバッファ16は、データセクタの物理セクタアドレスが書き込まれるセクタ管理手段を構成している。

### [0126]

図12はバッファデータエリア16aのビット構成図である。図12に示すように、それぞれのバッファセクタに16個ずつ設けられた2 [バイト] のバッファデータエリア16aは、データセクタの物理セクタアドレスが書き込まれる物理セクタアドレスエリア16b(bit8-bit0の9 [ビット])と、書き込み完了フラグが書き込まれる書き込み完了フラグエリア16c(bit9の1 [ビット])と、ダミービット="000000"のダミービットエリア(bit15-bit10の6 [ビット])とによって構成されている。

### [0127]

それぞれのバッファデータエリア16aに書き込まれた物理セクタアドレスは、これから時分割消去によってこれから消去するデータセクタおよび消去中のデータセクタの物理セクタアドレス、またはデータ書き込み可能なデータセクタの

物理セクタアドレスである。また、書き込み完了フラグエリア16cの書き込み 完了フラグは、書き込みが完了したか否かを示すフラグである。

[0128]

また、それぞれのバッファセクタのバッファ管理エリア16dには、バッファデータエリア16aが書き込まれるごとに、下位ビットから順に1ビットずつ" 1"が書き込まれる。これによって、バッファセクタ内のすでの書き込んだバッファデータエリア16aの位置、および次に書き込むバッファデータエリア16aの位置を識別できるようになっている。

[0129]

フラッシュデータメモリ11は、複数のデータセクタを同時に消去できるようになっており、さらにフラッシュデータメモリ11とイレースバッファ16は、消去時に同時に複数のセクタ(複数のデータセクタおよび1つのバッファセクタ)を選択できるようになっており、同時に複数のセクタを消去できる構成になっている。

[0130]

「アドレスポインタ14]

実施の形態3のアドレスポインタ14は、6 [ビット] のカウンタで構成され、イレースバッファ16のポインタの役割を果たし、上位2ビット(bit5, bit4)でイレースバッファ16のバッファセクタの位置を示し、下位4ビット(bit3-bit0)でバッファセクタ内でのバッファデータエリア16aの位置を示す。

[0131]

 $\lceil P \mid V \mid A \mid A \mid M \mid 1 \mid 7 \mid$ 

アドレスRAM17は、8 [kバイト]のデータ容量に相当する256セクタ 分のデータ(256個の論理セクタ)を識別するための8 [ビット]の論理セク タアドレスと同じアドレスでそれぞれのデータエリアをアクセスでき、それぞれ のデータエリア(アドレス管理エリア)に、データセクタ(物理セクタ)を識別 するための9 [ビット]の物理セクタアドレスを書き込みできる構成のRAMで ある。つまり、アドレスRAM17のそれぞれのアドレス管理エリアのアドレス は、8 [kバイト] のデータ容量のそれぞれの論理セクタアドレスと同じになっており、RAM17のそれぞれのアドレス管理エリアには、そのアドレスと同じ論理セクタアドレスを割り当たデータセクタ(物理セクタ)の物理セクタアドレスが書き込まれている。このアドレスRAM17は、8 [kバイト] のデータ容量の論理セクタアドレス数と同数のアドレス管理エリアを有し、それぞれのアドレス管理エリアを上記論理セクタアドレスと同じアドレスでアクセス可能であり、それぞれのアドレス管理エリアに、そのアドレスと同じ論理セクタアドレスを割り当てたデータセクタの物理セクタアドレスが書き込まれたアドレス管理手段を構成している。

### [0132]

論理セクタアドレスは、例えば8 [kバイト] のデータ容量に相当する256セクタ分(256個の論理セクタ)を識別してアクセス可能とするために、上記それぞれの論理セクタに付されるアドレスであり、256個の論理セクタでは、8 [ビット] である。また、物理セクタアドレスは、フラッシュデータメモリ11のデータセクタ (物理セクタ) を識別してアクセス可能とするために、それぞれのデータセクタに固定で付されるアドレスでである。フラッシュデータメモリ11には、論理セクタ数よりも多い288個のデータセクタが設けられているので、物理セクタアドレスは9 [ビット] になる。これらの288個のデータセクタの内の256個のデータセクタに256個の論理セクタアドレスがそれぞれ割り当てられる。そして、この実施の形態3では、それぞれの論理セクタアドレスには、固定不変のデータセクタが割り当てられるのではなく、その論理セクタアドレスのデータ書き換えごとに、異なるデータセクタが割り当てられる。

[0133]

#### 「アドレスラッチ13]

実施の形態3のアドレスラッチ13は、データセクタの物理セクタアドレスと同じビット構成の9 [ビット] のレジスタで構成され、フラッシュデータメモリ 11のデータ読み出しに使用するためにアドレスRAM17から読み出された物理セクタアドレスをラッチする。

[0134]

この実施の形態3のフラッシュメモリ部1のフラッシュデータメモリ11は、288 [セクタ] で構成されており、8 [kバイト] のデータ容量よりも32 [セクタ] 多い構成になっている。この上記データ容量よりも多い32 [セクタ] の内、16 [セクタ] は、上記実施の形態1と同様の時分割消去を可能にするために設けられたものであり、残りの16 [セクタ] は、不良セクタをリカバリするために設けられたものである。

[0135]

そして、この実施の形態3は、書き換えデータをその論理セクタアドレスが割り当てられていた第1のデータセクタとは異なる第2のデータセクタに書き込んで、上記の論理セクタアドレスの割り当てデータセクタを第1のデータセクタから第2のデータセクタに変更し、セクタを完全に消去するのにかかる時間よりも短い時間(ただし、セクタを完全に消去するのにかかる時間の1/16の時間以上)でデータ書き換え処理ごとに消去処理をすることによって、上記第1のデータセクタを合計16回のデータ書き込み処理で時分割に消去することを特徴とするものである。

[0136]

「データ書き換え動作]

このような実施の形態3のデータ書き換え処理は、上記実施の形態1と同様に、AP-ROM3b内のアプリケーションプログラムからC-ROM3a内のデータ書き換えサブルーチン(データ書き換え制御プログラム)をコールし、制御部4がそのデータ書き換えサブルーチンに従って制御する。以下に実施の形態3のデータ書き換え動作について説明する。

[0137]

図13は本発明の実施の形態3のデータ書き換え処理を示すフローチャートである。図13および以下の説明では、フラッシュデータメモリ11およびイレースバッファ16のメモリセルの消去状態を"0"、書き込み状態を"1"としている。

[0138]

図13および以下の説明において、Pはアドレスポインタ14にセットされた

データ(ポインタデータ)である。また、ERPおよびCHKはRAM2(図1参照)内に設けられた変数である。また、Addは、書き換えデータの論理セクタアドレス(書き換え論理アドレス)である。

[0139]

また、BUF [P], BUF [ERP], BUF [P-15] は、それぞれバッファデータエリア (図10の16a参照) であって、BUF [P] は、ポインタデータPの位置のバッファデータエリアであり、BUF [ERP] は、変数ERPをポインタデータとしたときの位置のバッファデータエリアであり、BUF [P-15] は、P+15をポインタデータとしたときの位置のバッファデータエリアである。ただし、ここでは64個のバッファデータエリアをサイクリックに使用するため、P-15は、ポインタデータPに15を加算し、その値を64で除算した剰余である。つまり、P+15は、

 $(P+15) \mod 64$ 

なる演算で求めた値である。

[0140]

また、MEM [BUF [ERP] のbit 8-0] は、物理セクタアドレスのデータセクタである。

[0141]

また、RAM [Add] は、RAM17内の書き換え論理アドレスAddと同じアドレスのデータエリア (アドレス管理エリア) である。

[0142]

図14および図15は本発明の実施の形態3のデータ書き換え処理の一例を説明する図であって、(1)は図13のステップStet1、(2)は図13のステップStet2、(3)は図13のステップStet3、(4)は図13のステップStet4の処理をした状態である。

[0143]

図14および図15のデータ書き換え処理の例では、そのデータ書き換え処理の開始前に、物理セクタアドレスP-Add1のデータセクタに、論理セクタアドレスAddの古いデータData1が書き込まれており、アドレスRAM17

のアドレスAddのデータエリアには、物理セクタアドレスP-Add1が書き込まれており、"000000", "000001", …, "011111"をポインタデータとしたときの位置の16個のバッファデータエリア16には、物理セクタアドレスE-Add1, E-Add1, …, E-Add32が書き込まれており、アドレスポインタ14にはポインタデータ"011111"がセットされている。

### [0144]

従って、図14および図15のデータ書き換え処理の例では、そのデータ書き換え処理の開始前に、物理セクタアドレスE-Add1からE-Add17までの17個のデータセクタはすでに消去を完了しており、物理セクタアドレスE-Add18のデータセクタはすでに15回の時分割消去処理がなされており、物理セクタアドレスE-Add32のデータセクタはすでに1回の時分割消去処理がなされている。

# [0145]

また、図14および図15のデータ書き換え処理の例では、書き換えデータは Data2であり、その論理セクタアドレス(書き換え論理アドレス)はAdd である。従って、データdata1が被書き換えデータである。

### [0146]

これら図14および図15のデータ書き換え処理を具体例として、図13のデータ書き換え処理について以下に説明する。

[0147]

### [ステップS21]

まず、図13のステップS21で、ポインタデータPに1を加算して更新する。ただし、ここでは64個のバッファデータエリアをサイクリックに使用するため、実際には、ポインタデータPに1を加算し、その値を64で除算して、その剰余でポインタデータPを更新する。つまり、

 $(P+1) \mod 64$ 

なる演算で求めた値でポインタデータPを更新する。

[0148]

更新前のポインタデータPは、前回のデータ書き換え処理で、消去するデータセクタの物理アドレスを書き込んだバッファデータエリア(図10の16aおよび図11参照)の位置を示し、更新されたポインタデータPは、今回のデータ書き換え処理で、消去するデータセクタの物理アドレスを書き込むバッファデータエリアの位置を示す。

[0149]

図14および図15の例では、ポインタデータPは、"011111"(10進法で31)から"100000"(10進法で32)に更新される。更新前のポインタデータP="011111"は、消去するデータセクタの物理アドレスE-Add32を前回書き込んだバッファデータエリア(図14(1)参照)の位置を示し、更新されたポインタデータP="100000"は、消去するデータセクタの物理アドレスP-Add1を今回書き込むバッファデータエリア(図14(2)参照)の位置を示す。

[0150]

[ステップS22]

この実施の形態3のデータ書き換え処理では、RAM2(図1参照)内に変数 ERPを設けてあり、図13のステップS22で、この変数ERPに、ポインタ データPから32を減算した値を書き込む。ただし、ここでは64個のバッファ データエリアをサイクリックに使用するため、実際には、あらかじめポインタデータPに32を加算し、その値を64で除算して、その剰余を変数ERPに書き込む。つまり、

 $(P+32) \mod 64$ 

なる演算で求めた値を変数ERPに書き込む。

[0151]

上記の変数 E R P は、消去が完了して書き込み可能になったデータセクタの物理セクタアドレスが書き込まれているバッファデータエリアの位置を示す。この実施の形態 3 では、フラッシュデータメモリ11を、8 [kバイト]のデータ容量よりも32 [セクタ] (時分割消去のための16 [セクタ] およびリカバリ処理のための16 [セクタ]) 多い構成としており、16回のデータ書き換え処理

での時分割消去によってセクタを完全に消去するので、リカバリ処理がなされていなければ、バッファデータエリアBUF [P] の32個前のバッファデータエリアから17個前のバッファデータエリアまでに書き込まれた物理セクタアドレスの16個のデータセクタが、消去が完了して書き込み可能になったデータセクタである。これら16個のバッファデータエリアの内の最初のバッファデータエリア(バッファデータエリアBUF [P] の32個前のバッファデータエリア)の位置を示すために、ポインタデータPから32を減算した値を変数EPRとしている。

[0152]

図14および図15の例では、

 $ERP = (32 + 32) \mod 64 = 0$ 

であり、この変数 ERP=0は、物理アドレスE-Add1が書き込まれたバッファデータエリア (図14(1)参照)の位置を示す。

[0153]

「ステップS23]

図13のステップS23では、バッファデータエリアBUF [ERP] の書き込み完了フラグ (bit9、図12の16c)が"0"であるか否かを判別し、書き込み完了フラグが"0"ならばステップS24に進み、"1"ならばステップS34に進む。

[0154]

[ステップS24]

[0155]

 $[\lambda F \gamma \beta S \delta \delta, S \delta \delta]$ 

次に図13のステップS25で、データセクタMEM [BUF [ERP] のb i t 8-0] のデータエリアに、書き換えデータを書き込み、図13のステップ S26で、そのデータセクタMEM [BUF [ERP] のb i t 8-0] のメモ



リ管理エリア (図10の11 a および図11参照) に、書き換え論理アドレス (bit7-bit0、図11の11 b参照) および有効セクタフラグ="1"(bit8、図11の11 c参照) を書き込む。

[0156]

図14および図15の例では、物理セクタアドレスE-Add1のデータセクタのデータエリアに、書き換えデータData2が書き込まれ、物理セクタアドレスE-Add1のデータセクタのメモリ管理エリアに、書き換え論理アドレスAdd(bit7-bit0)および有効セクタフラグ="1"が書き込まれる(図14(1)参照)。

[0157]

なお、上記ステップ S 2 5 , S 2 6 では、ワード単位の書き込みになるので、 1 7 回の書き込み処理をすることになる。ここで、 1 [ワード]の書き込み時間 を 2 0 [ $\mu$  s ]とすると、この書き込み処理に 3 4 0 [ $\mu$  s ]かかることになる

[0158]

[ステップS27]

次に図13のステップS27で、上記ステップS25, S26での書き込みが 正常になされたか否かをチェックし、書き込みが正常になされていればステップ S28に進み、書き込みが正常になされていなければステップS32に進む。

[0159]

 $[\lambda F \cup \beta S + E \cap A]$ 

ここまでのステップS21からS27まではステップStep1の処理を構成しており、このステップStep1の処理によって図14(1)の状態になる。図14(1)では、物理セクタアドレスE-Add1のデータセクタに、書き換えデータData2と、その論理セクタアドレス(書き換え論理アドレス)Addが書き込まれている。

[0160]

このように、ステップStep1は、ポインタデータPを更新して変数ERP を求め、バッファデータエリアBUF [ERP] に書き込まれている物理セクタ アドレスE-Add1に、新しい書き換えデータData2および書き換え論理 アドレスAddを書き込む処理である。

[0161]

[ステップS28, S29]

上記ステップS27で書き込みOKであれば、図13のステップS28で、ア ドレス管理エリアRAM [Add] にアクセスし、古いデータ(被書き換えデー タ)が書き込まれているデータセクタの物理セクタアドレスをバッファデータエ リア[P]のbit8-bit0に書き込み、図13のステップS29で、上記 古いデータの物理セクタアドレスを書き込んだバッファセクタのバッファ管理エ リア16d(図10参照)を更新する。

[0162]

[XFyJStep2]

これらのステップS28およびS29はステップStep2の処理を構成して おり、このステップStep2の処理によって図14(2)の状態になる。図1 4 (2) では、書き換え論理アドレスAddと同じアドレスRAM17のアドレ ス(アドレス管理エリアRAM[Add])に書き込まれている物理セクタアド レスであって古いデータ(被書き換えデータ)Datalが書き込まれているデ ータセクタの物理セクタアドレスであるP-Add1が、ポインタデータP=" 100000"の位置のバッファデータエリアに書き込まれ、この物理セクタア ドレスP-Add1を書き込んだバッファセクタのバッファ管理エリア16dが 、"00000000000000000"から"00000000000000 01"に更新されている。

[0163]

[ステップS30]

次に図13のステップS30で、アドレス管理エリアRAM [Add] に、新 しい書き換えデータを書き込んだデータセクタの物理セクタアドレスを書き込む

4 6

[0164]

[XFyJStep3]

このステップS30はステップStep3の処理となり、このステップStep3の処理によって図15(3)の状態となる。図15(3)では、書き換え論理アドレスAddと同じアドレスRAM17のアドレス(アドレス管理エリアRAM [Add])に、新しい書き換えデータData2を書き込んだデータセクタの物理セクタアドレスE-Add1が書き込まれている。

[0165]

[ステップS31]

次に図13のステップS31で、バッファデータエリアBUF [P] ~BUF [P-15] に書き込まれている物理セクタアドレスの16個のデータセクタと、バッファデータエリアBUF [P] のバッファセクタ (イレースバッファ16のポインタデータPの上位2ビットが示す位置のバッファセクタ) の次の位置の1個のバッファセクタとの合計17セクタを同時に消去する。

[0166]

[XFyJStep]

このステップ31はステップStep4の処理となり、このステップStep4の処理によって図15(4)の状態となる。図15(4)では、物理セクタアドレスE-Add18,E-Add19,…E-Add32,P-Add1の16個のデータセクタと、物理セクタアドレスP-Add1が書き込まれたバッファセクタの次の位置の1個のバッファセクタとの合計17セクタが時分割で消去されている。

[0167]

なお、この実施の形態3では、上記実施の形態1および2と同様に、フラッシュデータメモリ11のデコーダは複数のセクタを同時に選択できるようになっているので、同時に複数のデータセクタおよびバッファセクタを消去することができる。

[0168]

この実施の形態3でも、消去時間は、上記実施の形態1および2と同様に、データ書き換え処理ごとの16回の時分割消去によってそれぞれのセクタを完全に消去するので、上記ステップS31での消去時間は、従来の消去時間の1/16

の時間とすることができる。例えば、セクタの完全な消去に20[ms]必要な場合は、1.25[ms]の消去時間となる。

[0169]

上記ステップS31(上記ステップStep4)の処理の完了によって1回のデータ書き換え処理が完了したことになり、ソフト処理を除いた1回の書きデータ換え処理時間は、ステップStep1では340  $[\mu s]$ 、ステップStep2では1 [ワード] の書き込み2回で40  $[\mu s]$ 、ステップStep3ではRAMの書き込みなので数10~数100 [n s]、ステップStep4の消去では1.25 [m s] となるので、ステップStep3の書き込み時間を無視すると、0.34+0.04+1.25=1.63 [m s] となる。

[0170]

この実施の形態3では、論理セクタよりも多いデータセクタを設け、データセクタを物理セクタアドレスで管理することによって、上記実施の形態1および2のようなバッファセクタに一時書き込みした書き換えデータをデータセクタに移す書き込みが不要になるので、1回のデータ書き換え処理にかかる時間を上記実施の形態1および2よりも短くすることができる。

[0171]

### [リカバリ処理]

この実施の形態3では、書き込み不良が発生したときのリカバリ処理のために、16個のデータセクタが設けられている。図13のステップS27で書き込み不良が発生したときのリカバリ処理について以下に説明する。

[0172]

#### 「ステップS32]

上記ステップS 2 7で書き込みNGであれば、図13のステップS 3 2で、そのデータセクタMEM [BUF [ERP] のbit8-0] のメモリ管理エリア 11aに、不良セクタフラグ="1"(bit9、図11の11d参照)を書き込み、ステップS 3 4に進む。なお、上記ステップS 2 3 でバッファデータエリアBUF [ERP] の書き込み完了フラグが"1"であったときにも、ステップS 3 4 に進む。

[0173]

[ステップS34]

図13のステップS34では、変数ERPに1を加算して更新し、ステップS35に進む。ただし、ここでは64個のバッファデータエリアをサイクリックに使用するため、実際には、変数ERPに1を加算し、その値を64で除算して、その剰余で変数ERPを更新する。つまり、

(ERP+1) mod 64

なる演算で求めた値で変数ERPを更新する。

[0174]

図14および図15の例では、

 $ERP = (ERP + 1) \mod 64 = 1$ 

であり、この更新された変数 ERP=1 は、物理アドレス E-Add2 が書き込まれたバッファデータエリア(図 14(1) 参照)の位置を示す。

[0175]

この実施の形態3では、RAM2(図1参照)内に変数CHKを設けてあり、図13のステップS35で、上記ステップS21で更新したポインタデータPから上記ステップS34で更新した変数ERPを減算した値を変数CHKに書き込む。ただし、実際には、あらかじめポインタデータPに64を加算し、その加算値から変数ERPを減算し、その減算を64で除算して、その剰余を変数CHKに書き込む。つまり、

(P+64-ERP) mod 64

なる演算で求めた値を変数CHKに書き込む。

[0176]

上記の変数CHKは、上記ステップS34ですでに変数ERPに1が加算されているので、

 $1.5 \leq CHK \leq 3.1$ 

を範囲とする変数であり、この変数CHKから時分割消去のためのデータセクタの個数16を減算して1を加算した値CHK-15は、リカバリ処理に使用可能なデータセクタ数を示す。

[0177]

[ステップS36, S37]

次にステップS36で、変数CHKが16以上か否かを判別し、CHK≥16ならば、ステップS23に戻って再度ステップStep1の処理にトライし、CHK<16ならば、図13のステップS37で、異常終了処理をして、データ書き換え処理を終了する。

[0178]

図14および図15の例では、すでに消去を完了している物理セクタアドレス E-Add2, …, E-Add17016個のデータセクタがリカバリ処理に使用可能であり、物理セクタアドレスE-Add1のデータセクタの書き込みがNGであれば、再度のステップStep1の処理で、物理セクタアドレスE-Add2のデータセクタに書き込みをする。

[0179]

上記ステップS34からS37までは、主に書き込みエラーが発生したときに、不良データセクタを使用しないようにするとともに、その不良データセクタを他のデータセクタでリカバリする処理であり、この実施の形態3では16個の不良データセクタが発生するまで、リカバリ可能である。なお、不良データセクタの物理セクタアドレスは、書き込みエラーの発生以降は、イレースバッファ16およびアドレスRAM17に書き込まれることはないので、書き込みエラーの発生以降は、不良データセクタが使用されることはない。

[0180]

[データ読み出し動作]

実施の形態3のデータ読み出し動作について以下に説明する。まず、13[ビット]の読み出し論理アドレスの上位8ビットである読み出し論理セクタアドレスでアドレスRAM17をアクセスし、そのアドレス管理エリアに書き込まれている9[ビット]の物理セクタアドレスを読み出して、アドレスラッチ13に書き込む。そして、このアドレスラッチ13に書き込んだ物理アドレスセクタと、読み出し論理アドレスの下位4ビットとによって、フラッシュデータメモリ11からデータを読み出すことにより、データ読み出し処理が完了する。

### [0181]

### [初期設定処理]

この実施の形態3でも、上記実施の形態1と同様に、電源投入時にはアドレスポインタ14およびアドレスRAM17の初期設定処理が必要である。この実施の形態3の初期設定処理について以下に説明する。

### [0182]

まず、フラッシュデータメモリ11のメモリ管理エリア11aのデータを順次 読み出し、有効セクタフラグ(bit8、図11の11c参照)が"1"であり、かつ不良セクタフラグ(bit9、図11の11d参照)が"0"であるデータセクタについては、そのメモリ管理エリア11aに書き込まれている論理セクタアドレス(bit7-bit0、図11の11a参照)と同じアドレスのアドレスRAM17のアドレス管理エリアに、そのデータセクタの物理セクタアドレスを書き込む。

### [0183]

また、イレースバッファ16のバッファ管理エリア16dのデータを順にチェックして、前回のデータ書き換え処理で書き込んだバッファデータエリアを判別し、アドレスポインタ14にセットする。前回書き込んだバッファデータエリアは、バッファ管理エリア16dのビットを下位から順にチェックするによって、簡単に判別できる。以上で、アドレスRAM17およびアドレスポインタ14の初期設定が完了する。

#### [0184]

このような初期設定処理は、上記実施の形態1と同様に、C-ROM3a内にサブルーチンとして用意しておけば、AP-ROM3b内のアプリケーションプログラムからC-ROM3a内の初期設定サブルーチン(初期設定制御プログラム)をコールし、制御部4がその初期設定サブルーチンに従って制御する。

#### [0185]

以上のように実施の形態3によれば、書き換えデータをその論理セクタアドレスが割り当てられていた第1のデータセクタとは異なる第2のデータセクタに書き込んで、上記の論理セクタアドレスの割り当てデータセクタを第1のデータセ

クタから第2のデータセクタに変更し、上記第1のデータセクタを、完全な消去 にかかる時間ずつ消去処理によって、16回のデータ書き換え処理で時分割で消 去することにより、1回のデータ書き換え処理にかかる時間を短くできる。

[0186]

さらに、データ容量よりも多く設けたデータセクタの物理セクタアドレスと書き換えデータの論理セクタアドレスの関連をアドレスRAM17で管理することにより、書き換えデータを一時書き込みしたバッファセクタからデータセクタに移す処理が不要になるので、上記実施の形態1および2よりもさらに見かけの書き換え処理時間を短縮できる。

[0187]

また、データ容量よりも多く設けたデータセクタの物理セクタアドレスと書き換えデータの論理セクタアドレスの関連をアドレスRAM17で管理することにより、見かけの書き換えセクタアドレス(論理セクタアドレス)は同じでも、異なるデータセクタに書き換えデータを順次書き込んでいくので、フラッシュメモリの信頼性を向上させる効果が得られる。

[0188]

また、リカバリ処理のためのデータセクタを設け、不良セクタが発生した場合のリカバリ処理を可能にしたことによっても、フラッシュメモリの信頼性を向上させる効果が得られる。

[0189]

また、アドレスRAM17およびアドレスラッチ13によって、読み出し論理 セクタアドレスを物理セクタアドレスに変換してデータ読み出しをすることによ り、論理セクタと物理セクタの位置の違いをアプリケーションプログラムで意識 する必要がなく、データ読み出し処理時間を短くできる。

[0190]

また、上記実施の形態1および2と同様に、

目標の書き換え処理時間になるように時分割して消去するので、長時間の消去処理のためのバックアップ電源が必要ない。

[0191]

なお、上記実施の形態 1 および 2 において、アドレスの重複を判別しないよう にすることも可能である。

# [0192]

また、上記実施の形態3において、リカバリ処理をしないことも可能である。 この場合には、フラッシュデータメモリ11のデータセクタ数を16個減らすこ とができ、イレースバッファ16のバッファセクタ数を1個減らすことができる

### [0193]

また、上記実施の形態3では、フラッシュデータメモリ11とイレースバッファ16を別々のフラッシュメモリとして説明したが、1つのフラッシュメモリにまとめることも可能である。

### [0194]

また、上記実施の形態3では、フラッシュデータメモリ11をデータセクタ数がデータ容量よりも32個多い構成にしたが、さらにデータセクタ数を増やすことも可能である。データセクタ数を多くすれば、1つのデータセクタの実際の書き換え回数が減らせるので信頼性が向上するとともに、リカバリ処理に使用可能なデータセクタを増やすことができる。

#### [0195]

また、上記実施の形態3では、イレースバッファ16をバッファセクタ数が4 個の構成としたが、さらにバッファセクタ数を増やすことも可能である。

#### [0196]

また、上記実施の形態3では、データ書き込み処理ごとに、アドレスポインタ 14とバッファ管理エリア16 a の書き込み完了フラグから変数ERPを求めているが、電源投入時に変数ERPを求めておき、そのあとのデータ書き換え処理 ごとに変数ERPを更新することも可能である。

### [0197]

また、上記実施の形態1から3において、アドレスポインタ14をRAM2内に設けることも可能である。

#### [0198]

また、上記実施の形態 1 から 3 では、 1 / 1 6 に時分割して消去処理をする例を説明したが、時分割数は 2 以上の任意の数に設定可能である。時分割数を増やせば、さらに見かけ上の書き換え時間を短くできる。

[0199]

また、上記実施の形態1から3では、フラッシュメモリの書き込み状態を"1 "、消去状態を"0"として説明したが、逆にすることも可能である。

[0200]

### 【発明の効果】

以上説明したように本発明によれば、データ書き換え処理ごとのN回の時分割 消去によってそれぞれのセクタを完全に消去するので、1回のデータ書き換え処 理時間を短くできるという効果がある。

### 【図面の簡単な説明】

- 【図1】 本発明の実施の形態1のマイクロコンピュータの機能ブロック図である。
  - 【図2】 図1のフラッシュメモリ部の機能ブロック図である。
- 【図3】 図2のフラッシュバッファにおいての管理エリアのビット構成図である。
  - 【図4】 図2の読み出し用データ差し替え回路の構成例を示す図である。
- 【図5】 本発明の実施の形態1のマイクロコンピュータにおいての書き換え処理を説明する図である(その1)。
- 【図 6 】 本発明の実施の形態 1 のマイクロコンピュータにおいての書き換え処理を説明する図である(その 2)。
- 【図7】 本発明の実施の形態1のマイクロコンピュータにおいての書き換え処理を説明する図である(その3)。
- 【図8】 本発明の実施の形態1のマイクロコンピュータにおいての書き換え処理を示すフローチャートである。
- 【図9】 本発明の実施の形態2のマイクロコンピュータにおいての書き換え処理を示すフローチャートである。
  - 【図10】 本発明の実施の形態3のマイクロコンピュータにおいてのフラ

ッシュメモリ部の機能ブロック図である。

- 【図11】 図10においてのメモリ管理エリアのビット構成図である。
- 【図12】 図10においてのバッファデータエリアのビット構成図である
- 【図13】 本発明の実施の形態3のマイクロコンピュータにおいての書き 換え処理を示すフローチャートである。
- 【図14】 本発明の実施の形態3のマイクロコンピュータにおいての書き 換え処理の各ステップでの状態を示す図である(その1)。
- 【図15】 本発明の実施の形態3のマイクロコンピュータにおいての書き 換え処理の各ステップでの状態を示す図である(その2)。

### 【符号の説明】

1 フラッシュメモリ部、 2 RAM、 3 ROM、 3 a C-ROM 、 3 b AP-ROM、 4 制御部、 5 データバス、 6 アドレスバス、 11 フラッシュデータメモリ、 11 a メモリ管理エリア、 11 b 論理セクタアドレスエリア、 11 c 有効フラグエリア、 11 d 不良フラグエリア、 12 a 管理エリア、 12 b セクタアドレスエリア、 12 c 有効フラグエリア、 12 d 重複フラグエリア、 12 e セクタポインタエリア、 13 アドレスラッチ、 14 アドレスポインタ、 15 読み出し用データ差し替え回路、 16 イレースバッファ、 16 a バッファデータ、 16 b 物理セクタアドレスエリア、 16 c 書き込み完了フラグエリア、 16 d バッファ管理エリア、 17 アドレスRAM。

【書類名】

図面

【図1】



【図2】



【図4】



【図5】



【図6】



【図7】



【図8】







【図10】



【図11】



【図12】



【図13】



【図14】



出証特2003-3025076

【図15】



000H
P-Add1
Date2
Add

E-Add1

H000 ......

(3) Step 3の処理状態

(4) Step 4の処理状態

【書類名】 要約書

【要約】

【課題】 高速なデータ書き換えができるようにする。

【解決手段】 第 n 回目のデータ書き換え処理において、第 n 回目の書き換えデータをフラッシュバッファ12のバッファセクタに書き込み、セクタを完全に消去するのにかかる時間よりも短い時間でデータ書き換え処理ごとに消去処理をすることによって、第 n 回目から第 (n+15)回目までのデータ書き換え処理において、上記第 n 回目の書き換えデータを書き込むべきフラッシュデータメモリ11のデータセクタを時分割で消去し、第 (n+16)回目のデータ書き換え処理において、上記バッファセクタに書き込まれている上記第 n 回目の書き換えデータを、上記時分割で消去したデータセクタに書き込む。

【選択図】 図2

# 出願人履歴情報

識別番号

[000000295]

1. 変更年月日 1990年 8月22日 [変更理由] 新規登録

[変更理由]

新規登録

住 所

東京都港区虎ノ門1丁目7番12号

氏 名

沖電気工業株式会社